## EEL2020 Digital Design Lab Report Sem II AY 2023-24

| Experiment No.                  | : | 01                   |
|---------------------------------|---|----------------------|
| Name                            | : | Maulik Desai         |
| Roll No.                        | : | B22CS033             |
| Partner Name (Partner Roll No.) | : | Jay Mehta (B22CS034) |

#### **Objective**

Implement a half-adder on the PYNQ Z2 FPGA board using Verilog through the Vivado Design Suite.

## **Logic Design**



Made using circuitverse.org

### **Source Description**

## - Design source

The source file is a half\_adder module that generates an output carry and sum from inputs a, b.

#### - Constraint file

The XDC file was updated with the following changes:

| Ports<br>(from Verilog module) | Designation<br>(Input/Output) | PYNQ Component Type<br>(Button/LED/Switch etc. along with<br>number, eg. LD01, BTN2, etc.) | Pin Configuration<br>(from the PYNQ User Manual) |  |
|--------------------------------|-------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------|--|
| а                              | Input                         | SW1                                                                                        | M19                                              |  |
| b                              | Input                         | SW0                                                                                        | M20                                              |  |
| s                              | Output                        | LED0                                                                                       | R14                                              |  |
| С                              | Output                        | LED1                                                                                       | P14                                              |  |

#### - Simulation source

We have used a test bench for the input cases 00, 01, 10, 11 each that runs for 10 ns.

## **Simulation Results (Timing diagram)**



| Expected Truth Table |   |   |   | From the Timing Diagram |   |   |   |
|----------------------|---|---|---|-------------------------|---|---|---|
| а                    | b | С | s | а                       | b | С | s |
| 0                    | 0 | 0 | 0 | 0                       | 0 | 0 | 0 |
| 0                    | 1 | 0 | 1 | 0                       | 1 | 0 | 1 |
| 1                    | 0 | 0 | 1 | 1                       | 0 | 0 | 1 |
| 1                    | 1 | 1 | 0 | 1                       | 1 | 1 | 0 |

## **Elaborated Design**





The circuit diagram created by vivado matches the expected circuit diagram.

# **PYNQ Working Video**

#### □ Lab 01

This is the link to the Google Drive where all relevant documents are uploaded, including the codes folder, the working video, this report, and the images attached in this report.

#### **List of Attachments**

The following files are included in the zipped folder submitted along with this report in GC:-

- 1) half\_adder.v the half adder module
- 2) ha\_testbench.v the test bench
- 3) Constraints file